<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <form id="form">
      用户名: <input type="text" name="name" /> <br />
      密码: <input type="password" name="password" /><br />
      <button id="btn">提交</button>
    </form>

    <script>
      btn.onclick = function (e) {
        e.preventDefault()
        // 获取用户输入的数据
        // const name = document.querySelector('input[type=text]').value.trim()
        // const password = document
        //   .querySelector('input[type=password]')
        //   .value.trim()

        // 获取form表单的真实dom
        const form = document.getElementById('form')

        // 创建formdata
        // 此时formdata中就会存储form表单中所有写了name属性的表单项的值
        const formdata = new FormData(form)
        // console.log(formdata) //注意: 直接打印formdata是无法查看表单项的值的
        // console.log(formdata.get('name'))
        // console.log(formdata.get('password'))

        const xhr = new XMLHttpRequest()
        // 由于使用了formdata,所以只能用post请求方式
        xhr.open('post', 'http://localhost:5000/test')
        // 请求头不用写了,因为formdata会自动帮我们添加请求头
        // xhr.setRequestHeader(
        //   'content-type',
        //   'application/x-www-form-urlencoded'
        // )
        xhr.send(formdata)
      }
    </script>
  </body>
</html>
